//导入定义验证规则的包
const joi = require('joi');
//11位手机号码正则
const reg_phone =
  /^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])\d{8}$/;
/**
 * string() 值必须是字符串
 * alphanum() 值只能是包含 a-zA-Z0-9 的字符串
 * min(length) 最小长度
 * max(length) 最大长度
 * required() 值是必填项，不能为 undefined
 * pattern(正则表达式) 值必须符合正则表达式的规则
 */

// 用户名的验证规则
// const username = joi.string().alphanum().min(1).max(10).required();
const phone = joi.string().regex(reg_phone).required();
// 密码的验证规则
const password = joi
  .string()
  .pattern(/^[\S]{6,12}$/)
  .required();
//定义，email 的验证规则
const email = joi.string().email().required();
// dataUri() 指的是如下格式的字符串数据： 
const avatar = joi.string().dataUri().required();

// 定义验证注册和登录表单的规则对象
exports.reg_login_schema = {
  // 表示需要对 req.body 中的数据进行验证
  body: {
    phone,
    password,
  },
};

//验证规则对象 - 更新用户基本信息
exports.update_user_schema = {
  //需要对req.body 里面的数据进行验证
  body: {
    email,
  },
};

//验证规则对象 - 更新密码
exports.update_password_schema = {
  body: {
    // 使用 password 这个规则，验证 req.body.oldPwd 的值
    oldPassword: password,
    // 使用 joi.not(joi.ref('oldPwd')).concat(password) 规则，验证 req.body.newPwd 的值
    // 解读：
    // 1. joi.ref('oldPwd') 表示 newPwd 的值必须和 oldPwd 的值保持一致
    // 2. joi.not(joi.ref('oldPwd')) 表示 newPwd 的值不能等于 oldPwd 的值
    // 3. .concat() 用于合并 joi.not(joi.ref('oldPwd')) 和 password 这两条验证规则
    newPassword: joi.not(joi.ref('oldPassword')).concat(password),
  },
};

//验证规则对象 - 更新头像
exports.update_avatar_schema = {
  body: {
    avatar,
  },
};
